草庐IT

java - Java编译器的内部架构

全部标签

c - Go 语言使用 C 的内部结构

我希望能够在Go中将一个主机地址(让我们使用“www.google.be”)转换为sockaddr结构,然后在C代码中使用它。使用http://github.com/jbenet/go-sockaddr将主机地址转换为sockaddr_any结构并不难模块。我的代码有效,如下所示:ipAddr,_:=net.ResolveIPAddr("ip","www.google.be")sockAddr:=sockaddrnet.IPAddrToSockaddr(ipAddr)rawSockaddr,socklen,_:=sockaddr.SockaddrToAny(sockAddr)cStru

go - 为用户可以编辑的页面(例如维基百科/stackoverflow 页面)设计数据存储架构

想法是设计一个表/实体,其中包含一些基本信息,以及一个Markdown-Content字段,允许用户轻松创建表等。我是这样想的:typeTournamentstruct{IDin64`datastore:"-"`MDContent[]byte`datastore:",noindex"`NamestringURLstringDateCreatedint64CreatedBystringDateUpdatedint64UpdatedBystringApprovalStatusint64//0=tobedecided,1=approved,2=rejected,3=discontinuedA

go - 在已编译的 golang 可执行文件中隐藏静态字符串

我在代码中有这样的东西varmyString="teststring"编译运行stringsmyexecutable|grep"teststring"我在输出中看到了它。有没有办法在golang的可执行文件中隐藏明文字符串?单独的文件不是一个选项。它不是针对合格的黑客,而是针对可以在记事本中打开可执行文件并找到加密key的普通用户。 最佳答案 将文本写成一系列十六进制字节对您没有帮助——该字符串仍将按原样出现在二进制文件中。一个解决方案是对其进行加扰,可能是rot-13,或者将所有字节与某个值进行异或,或者甚至使用使用已知种子值初始

java - 我将如何在 Java 中实现 Go 的无缓冲 channel ?

Go同时提供unbufferedandbufferedchannels用于goroutines(线程)之间的通信。是straightforward在Java中将缓冲channel实现为有界缓冲区。Go的无缓冲channel要求一个协程在另一个协程接收时发送。任何人都可以向我解释如何在Java中实现它吗? 最佳答案 在Java中你可以使用SynchronousQueue,Java8的源代码在这里http://grepcode.com/file/repository.grepcode.com/java/root/jdk/openjdk/

GO-GTK 树莓派交叉编译

我正在使用GO-GTK来显示图像,该项目在amd64上运行良好,但是当我尝试为arm(RaspberryPi)交叉编译它时,出现以下错误。请告知如何将go-gtk从amd64交叉编译到arm(Raspberrypi3)。编译器输出如下github.com/mattn/go-gtk/glib#github.com/mattn/go-gtk/glibInfileincludedfrom/usr/lib/x86_64-linux-gnu/glib-2.0/include/glibconfig.h:9:0,from/usr/include/glib-2.0/glib/gtypes.h:32,f

go - 在 Bitbucket 管道中交叉编译 Golang

我正在尝试配置BitbucketPipelines以自动将Golang代码编译到Linux、OSX和Windows。我为此使用了Go的交叉编译功能;流水线运行Linux环境,通过设置GOOS和GOARCH的值交叉编译到OSX和Windows。但是,我无法让Windows构建正常工作-它出错并告诉我它找不到某个包。Linux和OSX构建均成功。但是,Windows构建失败,告诉我它找不到/go/src/github.com/sirupsen/logrus/hooks/syslog。之前的两个构建都成功地使用了这个包,并且运行了这两个ls/go/src/github.com/sirupse

go - 带有 gRPC 的 golang protocol buffers 可以在不同的 OS 平台上交叉编译和使用吗?

这个问题专门关于在不同的操作系统平台上编译和使用golangProtocolBuffer(使用gRPC),我还没有看到类似的问题。是否可以在Windows上编译一个.proto文件,然后在Linux上使用生成的文件?还是相反?我在Windows和Linux上编译了相同的.proto文件,diff显示了不同的结果。一个区别是Windows编译版本有时会在请求结构的字段中重复json,如下所示:Field1Name*type`protobuf,bytes,1,opt,name=my_name,json=myName"json:"my_name,omitempty"`而Linux版本是:Fi

google-app-engine - gcloud app deploy 尝试编译不需要的文件,我可以排除部分树吗?

我正在从包含更多项目的GOPATH部署GoogleAppEngine应用程序。出于某种原因,正在编译未从我正在上传的应用程序中引用的销售库(github.com/mattn/go-sqlite3),但失败了。有没有办法从gcloud中排除代码树中不需要的部分?我在gcloud的文档中找不到有关如何执行此操作的任何内容。Updatingservice[default]..........failed.ERROR:(gcloud.app.deploy)ErrorResponse:[9]Deploymentcontainsfilesthatcannotbecompiled:Compilefa

go - go 编译器降级后编译变慢

我最近在不知不觉中从Go1.8.4升级到了1.9。编译速度不受影响(至少没有注意到)。但是我在使用guru之类的工具时遇到了问题,所以我卸载了1.9并重新安装了1.8.4。之后,gorunfoo.go变得很慢。我怀疑旧版本的编译器无法使用1.9的缓存,必须从头开始重新编译所有内容-我没有证据。我的猜测是否正确?如果是这样,有什么方法可以重置编译器缓存吗? 最佳答案 删除文件夹$GOPATH\pkg。那就是包缓存文件夹。如果您使用-v标志运行编译器,它将列出所有正在编译的包。如果它继续编译您没有更改的相同包,那么您就知道它没有使用缓存

docker - docker 内部的 Golang 错误

在构建我的go应用程序时,我在docker中遇到了一个奇怪的错误:./main.go:31:9:cannotusedb(type*"github.com/khwerhahn/somerepo/vendor/github.com/jinzhu/gorm".DB)astype*"app/vendor/github.com/jinzhu/gorm".DBinargumenttoMigrateThecommand'/bin/sh-cgo-wrapperinstall'returnedanon-zerocode:2有人可以向我提示正确的方向吗,因为该应用程序在本地运行得很好。它就在docker容